<template>
  <div class="manage">
    <el-dialog
      :title="operateType === 'add' ? '新增用户' : '更新用户'"
      :visible.sync="isShow"
    >
      <CommonForm
        :formLabel="operateFormLabel"
        :form="operateForm"
        :inline="true"
        ref="form"
      />
      <div slot="footer" class="dialog-footer">
        <el-button @click="isShow = false">取消</el-button>
        <el-button type="primary" @click="confirm">确定</el-button>
      </div>
    </el-dialog>
    <div class="manage-header">
      <el-button type='primary' @click="addUser">+新增</el-button>
      <common-form
        :formLabel="FormLabel"
        :form="searchForm"
        :inline="true"
        ref="form"
      >
      <el-button type='primary' @click="getList">搜索</el-button>
      </common-form>
    </div>
    <CommonTab
      :tableData='tableData'
      :tableLabel='tableLabel'
      :config='config'
      @changePage='getList()'
      @edit='editUser'
      @del='delUser'
    />
  </div>
</template>

<script>
import CommonForm from "../../src/components/CommonForm";
import CommonTab from "../../src/components/CommonTab"
import {getUser} from '../../api/data'
export default {
  name: "User",
  components: {
    CommonForm,
    CommonTab,
  },
  data() {
    return {
      operateType: "add",
      isShow: false,
      operateFormLabel: [
        {
          model: "name",
          label: "姓名",
          type: "input",
        },
        {
          model: "age",
          label: "年龄",
          type: "input",
        },
        {
          model: "sex",
          label: "性别",
          type: "select",
          opts: [
            {
              label: "男",
              value: 1,
            },
            {
              label: "女",
              value: 0,
            },
          ],
        },
        {
          model: "birth",
          label: "生日",
          type: "date",
        },
        {
          model: "addr",
          label: "地址",
          type: "input",
        },
      ],
      operateForm: {
        name: "",
        addr: "",
        age: "",
        sex: "",
        birth: "",
      },
      FormLabel:[
        {
          label:'',
          model:'keyword',
          type:'input'
        }
      ],
      searchForm:{
        keyword:''
      },
      tableData:[],
      tableLabel:[
        {
          prop:'name',
          label:'姓名'
        },
        {
          prop:'age',
          label:'年龄'
        },
        {
          prop:'sexLabel',
          label:'性别'
        },
        {
          prop:'birth',
          label:'出生日期',
          width:200
        },
        {
          prop:'addr',
          label:'地址',
          width:320
        },
      ],
      config:{
        page:1,
        total:30
      }
    };
  },
  methods: {
    confirm() {
      if(this.operateType==='edit'){
        this.$http.post('/user/edit',this.operateForm).then(res=>{
          console.log(res)
          this.isShow=false
          this.getList()
        })
      }else{
        this.$http.post('/user/add',this.operateForm).then(res=>{
          console.log(res)
          this.isShow=false
          this.getList()
        })
      }
    },
    addUser(){
      this.isShow=true
      this.operateType='add'
      this.operateForm= {
        name: "",
        addr: "",
        age: "",
        sex: "",
        birth: "",
      }
    },
    getList(name=''){
      this.config.loading=true
      name?(this.config.page=1):''
      getUser({
        page:this.config.page,
        name
      }).then(({data:res})=>{
        console.log(res)
        this.tableData=res.list.map(item=>{
          item.sexlabel=item.sex==0?'女':'男'
          return item
        })
        this.config.total=res.count
        this.config.loading=false
      })
    },
    editUser(row){
      this.operateType='edit'
      this.isShow=true
      this.operateForm=row
    },
    delUser(row){
      this.$confirm("此操作将永久删除该文件，是否继续？",'提示',{
        confirmButtonText:'确认',
        cancelButtonText:'取消',
        type:'warning'
      }).then(()=>{
        const id=row.id
        this.$http.get('user/del',{
          params:{id}
        }).then(()=>{
          this.$message({
            type:'success',
            message:'删除成功'
          })
        })
      })
    }
  },
  created() {
    this.getList()
  },
};
</script>

<style lang='less' scoped>
.manage-header{
  display: flex;
  justify-content: space-between;
  align-items: center;
}
</style>